

# study-of-basic-gates

#### AIM:

To study and verify the truth table of logic gates in Quartus II using Verilog programming.

#### **Equipments Required:**

Software – Quartus prime

### Theory

Introduction Logic gates are the basic building blocks of any digital system. Logic gates are electronic circuits having one or more than one input and only one output. The relationship between the input and the output is based on a certain logic. Based on this, logic gates are named as

AND gate OR gate NOT gate NAND gate NOR gate Ex-NOR gate

### AND gate

The AND gate is an electronic circuit that gives a high output (1) only if all its inputs are high. A dot (.) is used to show the AND operation i.e. A.B or can be written as AB Y= A.B

#### OR gate

The OR gate is an electronic circuit that gives a high output (1) if one or more of its inputs are high. A plus (+) is used to show the OR operation. Y= A+B

### **NOT** gate

The NOT gate is an electronic circuit that produces an inverted version of the input at its output. It is also known as an inverter. If the input variable is A, the inverted output is known as NOT A. This is also shown as A' or A with a bar over the top, as shown at the outputs. Y= A'

..... ☐ README



gates are high if any of the inputs are low. The symbol is an AND gate with a small circle on the output. The small circle represents inversion. Y= (AB)'

#### NOR gate

This is a NOT-OR gate which is equal to an OR gate followed by a NOT gate. The outputs of all NOR gates are low if any of the inputs are high. The symbol is an OR gate with a small circle on the output. The small circle represents inversion. Y= (A+B)'

#### Ex-OR gate

The 'Exclusive-OR' gate is a circuit which will give a high output if either, but not both of its two inputs are high. An encircled plus sign  $(\oplus)$  is used to show the Ex-OR operation. Y=  $A \oplus B$ 

#### Ex-NOR gate

The 'Exclusive-NOR' gate circuit does the opposite to the EX-OR gate. It will give a low output if either, but not both of its two inputs are high. The symbol is an EX-OR gate with a small circle on the output. The small circle represents inversion.  $Y = A \oplus B$ 

#### **Procedure**

- 1. Type the program in Quartus software.
- 2. Compile and run the program.
- 3. Generate the RTL schematic and save the logic diagram.
- 4. Create nodes for inputs and outputs to generate the timing diagram.
- 5. For different input combinations generate the timing diagram.

#### **PROGRAM**

```
Q
Program for logic gates and verify its truth table in quartus using Verilog programming
 Developed by: Rakisha.R
 RegisterNumber: 25008669
                                                                                                          þ
module Gate_1 (
   input wire a,  // Input A
input wire b,  // Input B
   output wire and_out,
   output wire or out,
   output wire not_out, // only on A
   output wire nand out,
   output wire nor_out,
   output wire xor_out,
   output wire xnor_out
);
   assign and_out = a & b; // AND gate
   assign or_out = a | b;  // OR gate
assign not_out = ~a;  // NOT gate (on input A)
assign nand_out = ~(a & b);  // NAND gate
   assign nor_out = \sim(a | b); // NOR gate
   assign xor_out = a ^ b; // XOR gate
   assign xnor_out = ~(a ^ b); // XNOR gate
endmodule
```

#### Logic symbol & Truthtable

| Logical gate                                                                | Truth table                                                                                                                                               |
|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| AND gate $A = y = AB$ $B = AB$                                              | A         B         y=AB           0         0         0           0         1         0           1         0         0           1         1         1  |
| OR gate $A \xrightarrow{y = A+B}$                                           | A ↑ B     y=A→B       0     0     0       0     1     1       1     0     1       1     1     1                                                           |
| NOT gate $A = \overline{A}$                                                 | A y=A 0 1 1 0                                                                                                                                             |
| NAND gate $A = y = \overline{AB}$ $B = \overline{AB}$                       | A B y=AB 0 0 1 0 1 1 1 0 1 1 1 0                                                                                                                          |
| NOR gate $A = y = \overline{A+B}$ B                                         | A B y=A+B 0 0 1 0 1 0 1 0 0 1 1 0 1 1 0                                                                                                                   |
| EX-OR gate $A \longrightarrow y = A \oplus B$                               | A     B     y=A⊕B       0     0     0       0     1     1       1     0     1       1     1     0                                                         |
| EX-NOR gate $A \longrightarrow y = A \odot B$ $B \longrightarrow A \odot B$ | A         B         y=A⊙B           0         0         1           0         1         0           1         0         0           1         1         1 |

RTL realization Output:



#### Releases

No releases published Create a new release

## **Packages**

No packages published Publish your first package

# Languages

● VHDL 54.4% ● HTML 14.9% ● Stata 14.7% ● Verilog 13.3% ● Standard ML 2.7%

# Suggested workflows

Based on your tech stack



#### **SLSA Generic generator**

Generate SLSA3 provenance for your existing release workflows



Jekyll using Docker image

Configure

Configure

Package a Jekyll site using the jekyll/builder Docker image.

More workflows

Dismiss suggestions